<?php
/*
* 2007-2014 PrestaShop
*
* NOTICE OF LICENSE
*
* This source file is subject to the Open Software License (OSL 3.0)
* that is bundled with this package in the file LICENSE.txt.
* It is also available through the world-wide-web at this URL:
* http://opensource.org/licenses/osl-3.0.php
* If you did not receive a copy of the license and are unable to
* obtain it through the world-wide-web, please send an email
* to license@prestashop.com so we can send you a copy immediately.
*
* DISCLAIMER
*
* Do not edit or add to this file if you wish to upgrade PrestaShop to newer
* versions in the future. If you wish to customize PrestaShop for your
* needs please refer to http://www.prestashop.com for more information.
*
*  @author PrestaShop SA <contact@prestashop.com>
*  @copyright  2007-2014 PrestaShop SA
*  @license    http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
*  International Registered Trademark & Property of PrestaShop SA
*/

class IdentityControllerCore extends FrontController
{
	public $auth = true;
	public $php_self = 'identity';
	public $authRedirection = 'identity';
	public $ssl = true;

	public function init()
	{
		parent::init();
		$this->customer = $this->context->customer;
	}

	/**
	 * Start forms process
	 * @see FrontController::postProcess()
	 */
	public function postProcess()
	{
		$origin_newsletter = (bool)$this->customer->newsletter;

		if (Tools::isSubmit('submitIdentity'))
		{
			$email = trim(Tools::getValue('email'));

			if (Tools::getValue('months') != '' && Tools::getValue('days') != '' && Tools::getValue('years') != '')
				$this->customer->birthday = (int)(Tools::getValue('years')).'-'.(int)(Tools::getValue('months')).'-'.(int)(Tools::getValue('days'));
			elseif (Tools::getValue('months') == '' && Tools::getValue('days') == '' && Tools::getValue('years') == '')
				$this->customer->birthday = null;
			else
				$this->errors[] = Tools::displayError('Invalid date of birth.');

			if (Tools::getIsset('old_passwd'))
				$old_passwd = trim(Tools::getValue('old_passwd'));
			
			if (!Validate::isEmail($email))
				$this->errors[] = Tools::displayError('This email address is not valid');
			elseif ($this->customer->email != $email && Customer::customerExists($email, true))
				$this->errors[] = Tools::displayError('An account using this email address has already been registered.');
			elseif (!Tools::getIsset('old_passwd') || (Tools::encrypt($old_passwd) != $this->context->cookie->passwd))
				$this->errors[] = Tools::displayError('The password you entered is incorrect.');
			elseif (Tools::getValue('passwd') != Tools::getValue('confirmation'))
				$this->errors[] = Tools::displayError('The password and confirmation do not match.');
			else
			{
				$prev_id_default_group = $this->customer->id_default_group;

				// Merge all errors of this file and of the Object Model
				$this->errors = array_merge($this->errors, $this->customer->validateController());
			}

			if (!count($this->errors))
			{
				$this->customer->id_default_group = (int)$prev_id_default_group;
				$this->customer->firstname = Tools::ucwords($this->customer->firstname);

				if (Configuration::get('PS_B2B_ENABLE'))
				{
					$this->customer->website = Tools::getValue('website'); // force update of website, even if box is empty, this allows user to remove the website
					$this->customer->company = Tools::getValue('company');
				}

				if (!Tools::getIsset('newsletter'))
					$this->customer->newsletter = 0;
				elseif (!$origin_newsletter && Tools::getIsset('newsletter'))
					if ($module_newsletter = Module::getInstanceByName('blocknewsletter'))
						if ($module_newsletter->active)
							$module_newsletter->confirmSubscription($this->customer->email);

				if (!Tools::getIsset('optin'))
					$this->customer->optin = 0;
				if (Tools::getValue('passwd'))
					$this->context->cookie->passwd = $this->customer->passwd;
				if ($this->customer->update())
				{
					$this->context->cookie->customer_lastname = $this->customer->lastname;
					$this->context->cookie->customer_firstname = $this->customer->firstname;
					$this->context->smarty->assign('confirmation', 1);
				}
				else
					$this->errors[] = Tools::displayError('The information cannot be updated.');
			}
		}
		else
			$_POST = array_map('stripslashes', $this->customer->getFields());

		return $this->customer;
	}
	/**
	 * Assign template vars related to page content
	 * @see FrontController::initContent()
	 */
	public function initContent()
	{
		parent::initContent();

		if ($this->customer->birthday)
			$birthday = explode('-', $this->customer->birthday);
		else
			$birthday = array('-', '-', '-');

		/* Generate years, months and days */
		$this->context->smarty->assign(array(
				'years' => Tools::dateYears(),
				'sl_year' => $birthday[0],
				'months' => Tools::dateMonths(),
				'sl_month' => $birthday[1],
				'days' => Tools::dateDays(),
				'sl_day' => $birthday[2],
				'errors' => $this->errors,
				'genders' => Gender::getGenders(),
			));

		if (Module::isInstalled('blocknewsletter'))
			$this->context->smarty->assign('newsletter', (int)Module::getInstanceByName('blocknewsletter')->active);

		$this->setTemplate(_PS_THEME_DIR_.'identity.tpl');
	}

	public function setMedia()
	{
		parent::setMedia();
		$this->addCSS(_THEME_CSS_DIR_.'identity.css');
		$this->addJS(_PS_JS_DIR_.'validate.js');
	}

}
